package org.smart4j.framework.aspect;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.smart4j.framework.annotation.Aspect;
import org.smart4j.framework.annotation.Controller;
import org.smart4j.framework.proxy.AspectProxy;

import java.lang.reflect.Method;

/**
 * @Description:
 * @Author: Administrator
 * @Date: 2017/9/4 0004 下午 8:53
 */
@Aspect(Controller.class)
public class ControllerAspect extends AspectProxy {

    private static final Logger logger = LoggerFactory.getLogger(ControllerAspect.class);

    private long begin;

    @Override
    public void before(Class<?> cls, Method method, Object[] params) throws Throwable{
        logger.debug("-----------begin------------");
        logger.debug(String.format("class:%s",cls.getName()));
        logger.debug(String.format("method:%s",method.getName()));
        begin = System.currentTimeMillis();

    }

    @Override
    public void after(Class<?> cls, Method method, Object[] params) {
        logger.debug(String.format("time: %dms",System.currentTimeMillis() - begin));
        logger.debug("-----------end------------");
    }
}
